// @mixin merge-style(// 菜单选中后字体样式
//   $subMenuActiveText,
//   //菜单背景
//   $menuBg,
//   // 鼠标覆盖菜单时的背景
//   $menuHover,
//   // 子菜单背景
//   $subMenuBg,
//   // 鼠标覆盖子菜单时的背景
//   $subMenuHover
// ) {
//   .main-container {
//     // display: flex;
//     // flex-direction: column;
//     height: calc(100% - #{$headHeight});
//     transition: margin-left 0.28s;
//     margin-left: $sideBarWidth;
//     position: relative;
//     overflow-y: auto;
//     background: rgb(252, 249, 249);

//   }

//   .sidebar-container {
//     transition: width 0.28s;
//     width: $sideBarWidth !important;
//     background-color: $menuBg;
//     height: calc(100% - #{$headHeight});
//     position: fixed;
//     font-size: 0px;
//     top: $headHeight;
//     bottom: 0;
//     left: 0;
//     z-index: 1001;
//     overflow: hidden;
//     box-shadow: 0 0 1px #888888;

//     // reset element-plus css
//     .horizontal-collapse-transition {
//       transition: 0s width ease-in-out, 0s padding-left ease-in-out,
//       0s padding-right ease-in-out;
//     }

//     .scrollbar-wrapper {
//       overflow-x: hidden !important;
//     }

//     .el-scrollbar__bar.is-vertical {
//       right: 0px;
//     }

//     .el-scrollbar {
//       height: 100%;
//     }

//     &.has-logo {
//       .el-scrollbar {
//         height: calc(100% - 50px);
//       }
//     }

//     .is-horizontal {
//       display: none;
//     }

//     a {
//       display: inline-block;
//       width: 100%;
//       overflow: hidden;
//     }

//     .el-menu {
//       border: none;
//       height: 100%;
//       // background-color: $menuBg !important;
//       // width: 100% !important;
//     }

//     .el-menu-item,
//     .el-submenu__title {
//       color: $sideBarColor;
//       font-weight: 400;
//       font-size: 16px;
//     }

//     .el-menu {
//       background-color: transparent;
//     }

//     // menu hover
//     .submenu-title-noDropdown,
//     .el-submenu__title {
//       &:hover {
//         background-color: $menuHover !important;
//       }

//       background: $menuBg;
//       .el-icon-s-home{
//         margin-top:-3px;
//       }
//     }

//     .is-active > .el-submenu__title,
//     .is-active.submenu-title-noDropdown {
//       color: $subMenuActiveText !important;

//       i {
//         color: $subMenuActiveText !important;
//       }
//     }

//     .is-active {
//       transition: color 0.3s;
//       color: $subMenuActiveText !important;
//     }

//     & .nest-menu .el-submenu > .el-submenu__title,
//     & .el-submenu .el-menu-item {
//       font-size: 14px;
//       text-indent: 10px;
//       min-width: $sideBarWidth !important;
//       background-color: $subMenuBg !important;

//       &:hover {
//         background-color: $subMenuHover !important;
//       }
//     }
//   }

//   .hideSidebar {
//     .sidebar-container {
//       width: 54px !important;
//     }

//     .main-container {
//       margin-left: 54px;
//     }

//     .submenu-title-noDropdown {
//       padding: 0 !important;
//       position: relative;

//       .el-tooltip {
//         padding: 0 !important;
//       }
//     }

//     .el-submenu {
//       overflow: hidden;

//       & > .el-submenu__title {
//         .el-submenu__icon-arrow {
//           display: none;
//         }
//       }
//     }

//     .el-menu--collapse {
//       margin-left: -5px; //需优化的地方
//       .el-submenu {
//         & > .el-submenu__title {
//           & > span {
//             height: 0;
//             width: 0;
//             overflow: hidden;
//             visibility: hidden;
//             display: inline-block;
//           }
//         }
//       }
//     }
//   }

//   // 菜单折叠
//   .el-menu--vertical {
//     .el-menu--popup {
//       background-color: $subMenuBg !important;

//       .el-menu-item {
//         color: $sideBarColor;
//         background-color: $subMenuBg;

//         &:hover {
//           background-color: $subMenuHover;
//         }
//       }

//       .el-submenu__title {
//         color: $sideBarColor;
//       }
//     }

//     & > .el-menu {
//       i {
//         margin-right: 16px;
//       }
//     }

//     .is-active > .el-submenu__title,
//     .is-active.submenu-title-noDropdown {
//       color: $subMenuActiveText !important;

//       i {
//         color: $subMenuActiveText !important;
//       }
//     }

//     .is-active {
//       transition: color 0.3s;
//       color: $subMenuActiveText !important;
//     }

//     .nest-menu .el-submenu > .el-submenu__title,
//     .el-menu-item {
//       &:hover {
//         // you can use $subMenuHover
//         background-color: $menuHover !important;
//       }
//     }
//   }

//   .el-scrollbar__wrap {
//     overflow: auto;
//     height: 100%;
//   }

//   .el-menu--collapse .el-menu .el-submenu {
//     min-width: $sideBarWidth !important;
//   }

//   // 手机端
//   .mobile {
//     .main-container {
//       margin-left: 0px;
//     }

//     .sidebar-container {
//       transition: transform 0.28s;
//       width: $sideBarWidth !important;
//     }

//     &.hideSidebar {
//       .sidebar-container {
//         pointer-events: none;
//         transition-duration: 0.3s;
//         transform: translate3d(-$sideBarWidth, 0, 0);
//       }
//     }
//   }

//   .withoutAnimation {
//     .main-container,
//     .sidebar-container {
//       transition: none;
//     }
//   }
// }

// // 暗色主题
// body[data-theme="dark"] {
//   $subMenuActiveText: #f4f4f5;
//   $menuBg: #1b2a47;
//   $menuHover: #2a395b;
//   $subMenuBg: #1f2d3d;
//   $subMenuHover: #001528;

//   @include merge-style(
//       $subMenuActiveText,
//       $menuBg,
//       $menuHover,
//       $subMenuBg,
//       $subMenuHover
//   );
// }

// // 亮色主题
// body[data-theme="light"] {
//   $subMenuActiveText: #409eff;
//   $menuBg: #fff;
//   $menuHover: #e0ebf6;
//   $subMenuBg: #fff;
//   $subMenuHover: #e0ebf6;

//   @include merge-style(
//       $subMenuActiveText,
//       $menuBg,
//       $menuHover,
//       $subMenuBg,
//       $subMenuHover
//   );
// }

// 顶部栏
$headHeight: 64px; // 高度

// 侧边栏
$sideBarWidth: 210px; // 宽度
// $sideBarColor: #b7b5b5; // 文字颜色
// $sideBarColor: #303133; // 文字颜色
$sideBarBgColor: #1b2a47; // 背景颜色
$sideBarBgColorActive: #2a395b; // 背景颜色（激活状态）

@mixin merge-style(// 菜单选中后字体样式
  $menuActiveText,
  $subMenuActiveText,
  $sideBarColor, // 侧边菜单文字颜色
  //菜单背景
  $menuBg,
  // 鼠标覆盖菜单时的背景
  $menuHover,
  // 子菜单背景
  $subMenuBg,
  $subMenuBgActive, // 被选中子菜单背景样式
  // 鼠标覆盖子菜单时的背景
  $subMenuHover
) {
  .main-container {
    display: flex;
    flex-direction: column;
    // height: calc(100% - #{$headHeight});
    height: 100%;
    transition: margin-left 0.28s;
    margin-left: $sideBarWidth;
    position: relative;
    overflow-y: auto;
    background: #FDFDFF;
    padding: 8px;
  }

  .sidebar-container {
    transition: width 0.28s;
    width: $sideBarWidth !important;
    background-color: $menuBg;
    height: 100%;

    // height: calc(100% - #{$headHeight});
    position: fixed;
    font-size: 0px;
    top: $headHeight;
    bottom: 0;
    left: 0;
    z-index: 1001;
    overflow: hidden;
    box-shadow: 0 0 1px #888888;
    user-select: none;
    // background:gray;

    // reset element-plus css
    .horizontal-collapse-transition {
      transition: 0s width ease-in-out, 0s padding-left ease-in-out,
      0s padding-right ease-in-out;
    }

    .scrollbar-wrapper {
      overflow-x: hidden !important;
    }

    .el-scrollbar__bar.is-vertical {
      right: 0px;
    }

    .el-scrollbar {
      height: 100%;
    }

    &.has-logo {
      .el-scrollbar {
        height: calc(100% - 64px);
      }
    }

    .is-horizontal {
      display: none;
    }

    a {
      display: inline-block;
      width: 100%;
      overflow: hidden;
    }

    .el-menu {
      border: none;
      height: 100%;
      // background-color: $menuBg !important;
      // width: 100% !important;
    }

    .el-menu-item,
    .el-sub-menu__title {
      color: $sideBarColor;
      font-weight: 400;
      font-size: 14px;
      display: flex;
      &>i.snowfont {
        font-size: 20px;
        margin-right: 12px;
      }
    }

    .el-menu {
      background-color: transparent;
    }

    .el-sub-menu .el-menu-item {
      height: 48px;
      line-height: 48px;
    }

    // menu hover
    .submenu-title-noDropdown,
    .el-sub-menu__title {
      &:hover {
        background-color: $menuHover !important;
      }

      background: $menuBg;
    }

    .is-active > .el-sub-menu__title,
    .is-active.submenu-title-noDropdown {
      // color: $subMenuActiveText !important;
      color: $menuActiveText !important;

      i {
        color: $menuActiveText !important;
      }
    }

    .is-active {
      transition: color 0.3s;
      color: $subMenuActiveText !important;
    }

    .el-sub-menu__title {
      display: flex;
      align-items: center;
    }

    & .nest-menu .el-sub-menu > .el-sub-menu__title,
    & .el-sub-menu .el-menu-item {
      font-size: 14px;
      text-indent: 10px;
      min-width: $sideBarWidth !important;
      background-color: $subMenuBg !important;

      &:hover {
        background-color: $subMenuHover !important;
      }

      &.is-active {
        background-color: $subMenuBgActive !important;
      }
    }
  }

  .hideSidebar {
    .sidebar-container {
      width: 54px !important;
    }

    .main-container {
      margin-left: 54px;
    }

    .submenu-title-noDropdown {
      padding: 0 !important;
      position: relative;

      .el-tooltip {
        padding: 0 !important;
      }
    }

    .el-sub-menu {
      overflow: hidden;

      & > .el-sub-menu__title {
        .el-sub-menu__icon-arrow {
          display: none;
        }
      }
    }

    .el-menu--collapse {
      margin-left: -5px; //需优化的地方
      .el-sub-menu {
        & > .el-sub-menu__title {
          & > span {
            height: 0;
            width: 0;
            overflow: hidden;
            visibility: hidden;
            display: inline-block;
          }
        }
      }
    }
  }

  // 菜单折叠
  .el-menu--vertical {
    .el-menu--popup {
      background-color: $subMenuBg !important;

      .el-menu-item {
        color: $sideBarColor;
        background-color: $subMenuBg;

        &:hover {
          background-color: $subMenuHover;
        }
      }

      .el-sub-menu__title {
        color: $sideBarColor;
      }
    }

    & > .el-menu {
      i {
        margin-right: 16px;
      }
    }

    .is-active > .el-sub-menu__title,
    .is-active.submenu-title-noDropdown {
      color: $subMenuActiveText !important;

      i {
        color: $subMenuActiveText !important;
      }
    }

    .is-active {
      transition: color 0.3s;
      color: $subMenuActiveText !important;
    }

    .nest-menu .el-sub-menu > .el-sub-menu__title,
    .el-menu-item {
      &:hover {
        // you can use $subMenuHover
        background-color: $menuHover !important;
      }
    }
  }

  .el-scrollbar__wrap {
    overflow: auto;
    height: 100%;
  }

  .el-menu--collapse .el-menu .el-sub-menu {
    min-width: $sideBarWidth !important;
  }

  // 手机端
  .mobile {
    .main-container {
      margin-left: 0px;
    }

    .sidebar-container {
      transition: transform 0.28s;
      width: $sideBarWidth !important;
      // width:0 !important;
    }

    &.hideSidebar {
      .sidebar-container {
        pointer-events: none;
        transition-duration: 0.3s;
        transform: translate3d(-$sideBarWidth, 0, 0);
      }
    }
  }

  .withoutAnimation {
    .main-container,
    .sidebar-container {
      transition: none;
    }
  }
}

// 暗色主题
body[data-theme="dark"] {
  $menuActiveText: #5298FF;
  $subMenuActiveText: #C2CADE;
  $sideBarColor: #C2CADE;
  $menuBg: #00152B;
  $menuHover: #0D233F;
  $subMenuBg: #041B35;
  $subMenuBgActive: #14325B;
  $subMenuHover: #14325B;

  @include merge-style(
    $menuActiveText,
    $subMenuActiveText,
    $sideBarColor,
    $menuBg,
    $menuHover,
    $subMenuBg,
    $subMenuBgActive,
    $subMenuHover
  );
}

// 亮色主题
body[data-theme="light"] {
  $menuActiveText: #409eff;
  $subMenuActiveText: #409eff;
  $sideBarColor: #303133;
  $menuBg: #fff;
  $menuHover: #e0ebf6;
  $subMenuBg: #fff;
  $subMenuBgActive: #fff;
  $subMenuHover: #e0ebf6;

  @include merge-style(
    $menuActiveText,
    $subMenuActiveText,
    $sideBarColor,
    $menuBg,
    $menuHover,
    $subMenuBg,
    $subMenuBgActive,
    $subMenuHover
  );
}
